package Top;

import java.util.ArrayList;

public class Top53 {

    public int maxSubArray(int[] nums) {
        int pre=0;
        int sum=nums[0];
        for (int x : nums) {
            //过滤前一个数加上后一个数还没有后一个数大的情况
            pre=Math.max(pre+x,x);
            sum=Math.max(sum,pre);
        }
        return sum;
    }

    public static void main(String[] args) {
        int[] nums={-2,1,-3,4,-1,2,1,-5,4};
        Top53 top53=new Top53();
        System.out.println(top53.maxSubArray(nums));
    }
}
